# University of California, Santa Barbara

Department of Electrical and Computer Engineering

ECE 152A – Digital Design Principles

Midterm Exam #2 August 8, 2007

| Name                   |  |  |  |  |  |  |  |  |  |
|------------------------|--|--|--|--|--|--|--|--|--|
| Perm #                 |  |  |  |  |  |  |  |  |  |
| Lab Section            |  |  |  |  |  |  |  |  |  |
|                        |  |  |  |  |  |  |  |  |  |
| Problem #1 (25 points) |  |  |  |  |  |  |  |  |  |
| Problem #2 (25 points) |  |  |  |  |  |  |  |  |  |
| Problem #3 (25 points) |  |  |  |  |  |  |  |  |  |
| Problem #4 (25 points) |  |  |  |  |  |  |  |  |  |
| Total (100 points)     |  |  |  |  |  |  |  |  |  |

- This is a 75 minute exam; closed book, closed notes, no calculators.
- Answer all questions on the exam.

### Problem #1.

Complete the timing diagram (on the following page) for the circuit shown below. Assume all gate delays are equal and all are much shorter than the clock period. You can also assume that both setup and hold times are satisfied.

I'm more interested in the order of transitions (indicated by arrows, as shown on the timing diagram), than the detailed timing numbers.





#### Problem #2.

In this problem, you are to design a 3-bit counter which can function as either a modulo 5 counter (0,1,2,3,4,0...) or a Fibonacci Sequence counter (0,1,1,2,3,5,0...), based on a single input B. When B is high the counter counts in binary (mod 5); when B is low the counter sequences through the first 6 Fibonacci numbers.

If the B input changes, the next value of the counter should be next greater number for the new sequence. For instance, if the counter is at binary 3 and B goes low, the next output should be 5 (Fibonacci count). Similarly, if the counter is at Fibonacci 3 and B goes high, the next output should be 4 (binary count).

1. (3 points) Construct the state diagram (on the following page) for the binary (mod 5) portion of the counter. Assume for this part that the input B is always high; we'll add the Fibonacci capability later.

For each state, include the binary encoding of the state is (the values of state variables A, B and C) and the three bit numerical output (they can be the same) on the state diagram as shown below for state 0 0 0 and output = 0 0 0.

|         | STATE |
|---------|-------|
| OUTPUTS |       |
| A       |       |

2. (4 points) Construct the state table for the design specified in part 1 above. The table should be in the form:



 (5 points) If we were to implement this design with edge triggered T flip flops, what would the T inputs to the three flip flops be (T<sub>A</sub>, T<sub>B</sub>, T<sub>C</sub>)? Include both next State Maps and T Flip Flop input (excitation) maps in your answer. 4. (10 points) Now complete the design by adding the capability to count the first 6 Fibonacci numbers. Construct a state diagram and indicate the decimal (or binary) value of the state variables, A, B and C and the decimal (or binary) value of the output number associated with that state.

(<u>Hint</u>: Note that the Fibonacci sequence repeats the number 1. For this problem, assume that a 3 input, 3 output combinational circuit is available to translate the values of the current state variables to a numerical output; i.e., this is a Moore machine).

5. (3 points) Construct the state table for the state diagram with the derived in part 4 above. It should be in the form:

| PS |   |   |  | <u>NS, B=0</u> |   |   | <u>NS, B=1</u> |   |   |        | Present |   |  |
|----|---|---|--|----------------|---|---|----------------|---|---|--------|---------|---|--|
| A  | В | С |  | Α              | В | С | <br>А          | В | C | Output |         |   |  |
| 0  | 0 | 0 |  | 0              | 0 | 1 | <br>0          | 0 | 1 | 0      | 0       | 0 |  |

## Problem #3.

In this problem you are asked to design a synchronous 4-bit, up / down counter with parallel load capability (load all four bits synchronously) and an asynchronous reset (all bits asynchronously set to 0) using Verilog.

The register can perform the following synchronous functions, based on a 2 bit input (F1, F0).

- 00 Hold (register contents remain unchanged)
- 01 Increment
- 10 Decrement
- 11 Load from external inputs (inputs are labeled D3 : D0)

The contents of the register are labeled Q3 : Q0 and the low true, asynchronous reset signal is labeled Rn.

Your solution doesn't have to be precisely, syntactically correct, but all the elements should be present. Your design should be simple, straightforward and easily understood by an experienced Verilog designer.

## Problem #4.

A finite state machine is constructed using positive edge triggered, JK flip flops as shown in the schematic below:



1. (2 points) What are the J and K inputs to the A and B flip flops:  $J_A$ ,  $K_A$ ,  $J_B$ ,  $K_B$ , (if you get this wrong, the rest of your answer will be wrong).

2. (12 points) Derive next state equations for the flip flops (recall the characteristic equation for a JK flip flop is Q+ = JQ' + K'Q).

3. (5 points) Map the next state equations onto K maps.

4. (3 points) Construct a state table for the machine.

5. (3 points) Construct a state diagram for the machine.